import { Form, Input, Button, Checkbox, Card, message } from 'antd'
import logo from '@/assets/logo.png'
import './index.scss'
import { useDispatch } from 'react-redux'
import { fetchLogin } from '@/store/modules/user'
import { useNavigate } from 'react-router-dom'

const Login = () => {
    const dispatch = useDispatch()
    const navigate = useNavigate()
    const onFinish = async (values) => {
        // 触发异步action fetchLogin
        // await并非没影响，此处语法检测错误
        await dispatch(fetchLogin(values))
        // 1.跳转到首页
        navigate('/')
        // 2.提示用户登录成功
        message.success('登录成功')
    }
    return (
        <div className="login">
            <Card className="login-container">
                <img className="login-logo" src={logo} alt="" />
                {/* 登录表单 */}
                <Form onFinish={onFinish} validateTrigger="onBlur">
                    <Form.Item
                        name="mobile"
                        // 多条校验逻辑 先校验第一条 第一条通过之后再校验第二条
                        rules={[
                            { required: true, message: '请输入手机号!' },
                            {
                                pattern: /^(\+86|0086)?\s*1[3-9]\d{9}$/,
                                message: '请输入正确的手机号格式!'
                            }
                        ]}>
                        <Input size="large" placeholder="请输入手机号" />
                    </Form.Item>

                    <Form.Item
                        name="code"
                        rules={
                            [{ required: true, message: '请输入验证码!' }]}>
                        <Input size="large" placeholder="请输入验证码" />
                    </Form.Item>

                    <Form.Item>
                        <Checkbox className="login-checkbox-label">
                            我已阅读并同意「用户协议」和「隐私条款」
                        </Checkbox>
                    </Form.Item>

                    <Form.Item>
                        <Button type="primary" htmlType="submit" size="large" block>
                            登录
                        </Button>
                    </Form.Item>
                </Form>
            </Card>
        </div>
    )
}

export default Login